| 31         | 25               | 24         | 19 15                      | 14 12  | 11       | 7         | 6   | 0   | _  |     |    |
|------------|------------------|------------|----------------------------|--------|----------|-----------|-----|-----|----|-----|----|
| fun        | ct7              | rs2        | rs1                        | funct3 | rd       |           | орс | ode | R类 |     |    |
|            | imm[11:0]        |            | rs1                        | funct3 | rd       | rd opcode |     | rd  |    | ode | I类 |
| imm[       | imm[11:5] rs2    |            | rs1                        | funct3 | imm[4:0] | imm[4:0]  |     | ode | S类 |     |    |
| imm[12     | imm[12 10:5] rs2 |            | rs2 rs1 funct3 imm[4:1 11] |        | 1]       | орс       | ode | SB类 |    |     |    |
| imm[31:12] |                  |            |                            |        | rd       |           | орс | ode | U类 |     |    |
|            | imm[2            | 20 10:1 11 | rd                         |        | орс      | ode       | UJ类 |     |    |     |    |

# RV32I 基本指令集

|                |                      |            |            |       |                                       |         | •       |
|----------------|----------------------|------------|------------|-------|---------------------------------------|---------|---------|
|                |                      | imm[31:12] |            |       | rd                                    | 0110111 | LUI     |
|                |                      | imm[31:12] |            |       | rd                                    | 0010111 | AUIPC   |
| imm[20 10:1 11 |                      |            | 19:12]     |       | rd                                    | 1101111 | JAL     |
| imm[11:0]      |                      |            | rs1        | 000   | rd                                    | 1100111 | JALR    |
| imm[1]         | 2 10:5]              | rs2        | rs1        | 000   | imm[4:1 11]                           | 1100011 | BEQ     |
|                | 2   10:5]            | rs2        | rs1        | 001   | imm[4:1 11]                           | 1100011 | BNE     |
|                | 2 10:5]              | rs2        | rs1        | 100   | imm[4:1 11]                           | 1100011 | BLT     |
|                | 2   10:5]            | rs2        | rs1        | 101   | imm[4:1 11]                           | 1100011 | BGE     |
|                | 2   10:5]            | rs2        | rs1        | 110   | imm[4:1 11]                           | 1100011 | BLTU    |
| imm[1:         |                      | rs2        | rs1        | 111   | imm[4:1 11]                           | 1100011 | BGEU    |
| [              | imm[11:0             |            | rs1        | 000   | rd                                    | 0000011 | LB      |
|                | imm[11:0             |            | rs1        | 001   | rd                                    | 0000011 | LH      |
|                | imm[11:0             |            | rs1        | 010   | rd                                    | 0000011 | LW      |
|                | imm[11:0             |            | rs1        | 100   | rd                                    | 0000011 | LBU     |
|                | imm[11:0             | -          | rs1        | 101   | rd                                    | 0000011 | LHU     |
| imm            |                      | rs2        | rs1        | 000   | imm[4:0]                              | 0100011 | SB      |
| imm            |                      | rs2        | rs1        | 001   | imm[4:0]                              | 0100011 | SH      |
|                | [11:5]               | rs2        | rs1        | 010   | imm[4:0]                              | 0100011 | SW      |
| 1111111        | imm[11:0             |            | rs1        | 000   |                                       | 0010011 | ADDI    |
|                |                      | •          |            | 010   | rd                                    | 0010011 | SLTI    |
|                | imm[11:0<br>imm[11:0 |            | rs1<br>rs1 | 010   | rd                                    | 0010011 | SLTIU   |
|                |                      | •          |            |       | rd                                    |         | 1       |
|                | imm[11:0             | •          | rs1        | 100   | rd                                    | 0010011 | XORI    |
|                | imm[11:0             | -          | rs1        | 110   | rd                                    | 0010011 | ORI     |
| 000/           | imm[11:0             |            | rs1        | 111   | rd                                    | 0010011 | ANDI    |
|                | 0000                 | shamt      | rs1        | 001   | rd                                    | 0010011 | SLLI    |
|                | 0000                 | shamt      | rs1        | 101   | rd                                    | 0010011 | SRLI    |
|                | 0000                 | shamt      | rs1        | 101   | rd                                    | 0010011 | SRAI    |
|                | 0000                 | rs2        | rs1        | 000   | rd                                    | 0110011 | ADD     |
|                | 0000                 | rs2        | rs1        | 000   | rd                                    | 0110011 | SUB     |
|                | 0000                 | rs2        | rs1        | 001   | rd                                    | 0110011 | SLL     |
|                | 0000                 | rs2        | rs1        | 010   | rd                                    | 0110011 | SLT     |
|                | 0000                 | rs2        | rs1        | 011   | rd                                    | 0110011 | SLTU    |
|                | 0000                 | rs2        | rs1        | 100   | rd                                    | 0110011 | XOR     |
|                | 0000                 | rs2        | rs1        | 101   | rd                                    | 0110011 | SRL     |
|                | 0000                 | rs2        | rs1        | 101   | rd                                    | 0110011 | SRA     |
|                | 0000                 | rs2        | rs1        | 110   | rd                                    | 0110011 | OR      |
|                | 0000                 | rs2        | rs1        | 111   | rd                                    | 0110011 | AND     |
| 0000 Pred      |                      | Succ       | 00000      | 000   | 00000                                 | 0001111 | FENCE   |
| 0000 0000      |                      | 0000       | 00000      | 001   | 00000                                 | 0001111 | FENCE.I |
| 00000000000    |                      | 00000      | 000        | 00000 | 1110011                               | ECALL   |         |
| 00000000001    |                      |            | 00000      | 000   | 00000                                 | 1110011 | EBREA   |
| csr            |                      |            | rs1        | 001   | rd                                    | 1110011 | CSRRW   |
| csr            |                      |            | rs1        | 010   | rd                                    | 1110011 | CSRRS   |
| csr            |                      |            | rs1        | 011   | rd                                    | 1110011 | CSRRC   |
|                | csr                  |            | zimm       | 101   | rd                                    | 1110011 | CSRRW   |
|                | csr                  |            | zimm       | 110   | rd                                    | 1110011 | CSRRSI  |
|                | csr                  |            | zimm       | 111   | rd                                    | 1110011 | CSRRCI  |
|                |                      |            |            |       | · · · · · · · · · · · · · · · · · · · |         |         |

| 31        | 25    | 24         | 19 15 | 14 12  | 11     | 7   | 6      | 0   | _  |
|-----------|-------|------------|-------|--------|--------|-----|--------|-----|----|
| funct7    |       | funct7 rs2 |       | funct3 | rd     |     | opcode |     | R类 |
| imm[11:0] |       |            | rs1   | funct3 | rd     | орс | ode    | I类  |    |
| imm[:     | 11:5] | rs2        | rs1   | funct3 | imm[4: | 0]  | орс    | ode | S类 |

## RV64I基本指令集(除了RV32I之外)

| imm[11:   | rs1          | 110 | rd  | 0000011  | LWU     |       |  |  |  |
|-----------|--------------|-----|-----|----------|---------|-------|--|--|--|
| imm[11:   | imm[11:0]    |     |     | rd       | 0000011 | LD    |  |  |  |
| imm[11:5] | rs2          | rs1 | 011 | imm[4:0] | 0100011 | SD    |  |  |  |
| 000000    | shamt        | rs1 | 001 | rd       | 0010011 | SLLI  |  |  |  |
| 000000    | shamt        | rs1 | 101 | rd       | 0010011 | SRLI  |  |  |  |
| 010000    | 010000 shamt |     | 101 | rd       | 0010011 | SRAI  |  |  |  |
| imm[11:   | imm[11:0]    |     |     | rd       | 0011011 | ADDIW |  |  |  |
| 0000000   | shamt        | rs1 | 001 | rd       | 0011011 | SLLIW |  |  |  |
| 0000000   | shamt        | rs1 | 101 | rd       | 0011011 | SRLIW |  |  |  |
| 0100000   | shamt        | rs1 | 101 | rd       | 0011011 | SRAIW |  |  |  |
| 0000000   | rs2          | rs1 | 000 | rd       | 0111011 | ADDW  |  |  |  |
| 0100000   | 0100000 rs2  |     | 000 | rd       | 0111011 | SUBW  |  |  |  |
| 0000000   | rs2          | rs1 | 001 | rd       | 0111011 | SLLW  |  |  |  |
| 0000000   | rs2          | rs1 | 101 | rd       | 0111011 | SRLW  |  |  |  |
| 0100000   | rs2          | rs1 | 101 | rd       | 0111011 | SRAW  |  |  |  |

### RV32M标准扩展

| 0000001 | rs2 | rs1 | 000 | rd | 0110011 | MUL    |
|---------|-----|-----|-----|----|---------|--------|
| 0000001 | rs2 | rs1 | 001 | rd | 0110011 | MULH   |
| 0000001 | rs2 | rs1 | 010 | rd | 0110011 | MULHSU |
| 0000001 | rs2 | rs1 | 011 | rd | 0110011 | MULHU  |
| 0000001 | rs2 | rs1 | 100 | rd | 0110011 | DIV    |
| 0000001 | rs2 | rs1 | 101 | rd | 0110011 | DIVU   |
| 0000001 | rs2 | rs1 | 110 | rd | 0110011 | REM    |
| 0000001 | rs2 | rs1 | 111 | rd | 0110011 | REMU   |

## RV64M标准扩展(除了RV32M之外)

| 0000001 | rs2 | rs1 | 000 | rd | 0111011 | MULW  |
|---------|-----|-----|-----|----|---------|-------|
| 0000001 | rs2 | rs1 | 100 | rd | 0111011 | DIVW  |
| 0000001 | rs2 | rs1 | 101 | rd | 0111011 | DIVUW |
| 0000001 | rs2 | rs1 | 110 | rd | 0111011 | REMW  |
| 0000001 | rs2 | rs1 | 111 | rd | 0111011 | REMUW |

## RV32A标准扩展

| 00010 | а | rl | 00000 | rs1 | 010 | rd | 0101111 | LR.W      |
|-------|---|----|-------|-----|-----|----|---------|-----------|
| 00011 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | SC.W      |
| 00001 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOSWAP.W |
| 00000 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOADD.W  |
| 00100 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOXOR.W  |
| 01100 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOAND.W  |
| 01000 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOOR.W   |
| 10000 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOMIN.W  |
| 10100 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOMAX.W  |
| 11000 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOMINU.W |
| 11100 | а | rl | rs2   | rs1 | 010 | rd | 0101111 | AMOMAXU.W |